Method and system for rendering Unicode complex text data in a printer

ABSTRACT

A method and system for providing a printer for printing an encoded data stream. The stream includes a section of complex text data. The code is preferably Unicode, and the complex text data is preferably Unicode complex text. The printer includes a font, a text parser, and a layout engine. The font includes a plurality of glyphs. The text parser parses the data stream to determine the section of complex text data in the data stream. The layout engine is coupled to the text parser and with the font. The layout engine receives the section of complex text data from the text parser and determines at least one of the plurality of glyphs and glyph positions corresponding to the section of complex text data.

FIELD OF THE INVENTION

[0001] The present invention relates to computer systems, and more particularly to a method and system for rendering complex text data, such as Unicode complex text, in a printer.

BACKGROUND OF THE INVENTION

[0002] In order to print data, such as text, the data to be printed is encoded. The encoding schemes represent the characters to be printed. Because there are numerous written languages having distinct characters, the encoding schemes represent, for example, the characters in different languages. Although there are various schemes utilized to encode data, Unicode is a standardized code for representing text. Unicode includes a code word for each character in a particular language. For example, one code word in Unicode would represent a Chinese pictograph, another code word in Unicode represents an Arabic character, while yet another code word in Unicode represents a character in the Latin alphabet. The code words also have a particular length. Unicode uses a two byte code word for most characters. In addition, Unicode groups characters in a particular numeric range. For example, all Arabic characters are represented by Unicode code words within a particular numeric range.

[0003] In addition to using a particular encoding scheme, a font is also used to print the data stream. For example, an Open Type font might be used in conjunction with Unicode. The font specifies the glyph, which is the character shape actually printed by a conventional printer. Thus, the font would indicate whether the “A” represented by the Unicode code word is a Times New Roman glyph or an Arial glyph. The font could also include Chinese pictographs, Arabic characters or other characters. The font is used to convert between the code word and the glyph. For example, the font might include an encoding table and a glyph table. The encoding table would be used to convert the code word for a particular encoding scheme to a corresponding glyph index. The glyph table would be used to convert the glyph index to a particular glyph. The glyph would then be printed in a particular location on the page corresponding to the code word.

[0004] Using Unicode code words in a data stream, a conventional computer system could convert Unicode to other data, for example a bit map of the glyph to be printed and the location of the glyph. This data is provided to a conventional printer. The conventional printer would print the glyph in the location corresponding to the Unicode code word. In such rendering a particular code word or set of code words always corresponds to the same glyph or set of glyphs. Thus, one-to-one rendering of a code word to a glyph is performed.

[0005] Although encoding schemes such as Unicode provide a code word for each character, one of ordinary skill in the art will readily recognize that in certain, complex languages, the glyph used to represent a given character depends upon its context. For example, in Arabic, Indic, and Thai language groups, the glyph used depends upon the surrounding characters. In addition, certain languages are written in a different order. English is typically written from left to right. However, other scripts are written from right to left. In addition, some scripts are written both right to left and left to right. For example, in Hebrew and Arabic, text is written right to left, but numbers are written left to right. As a result, the processing of code words is highly dependent upon the language. For complex languages, for example those read in a different order or having characters that are context dependent, identity and/or order of glyphs depend upon the context. Thus, printing of complex text data, such as the complex text described above, cannot be performed using one-to-one rendering.

[0006]FIG. 1 depicts a conventional system 10 used to print data including complex text data. The conventional system 10 might print text using an encoding scheme such as Unicode. For clarity, the conventional system 10 is described in the context of Unicode. The conventional system 10 includes a computer system 20 and a printer 30. The computer system 10 might include one or more clients and a print server or a desktop computer. The conventional computer system 20 includes a conventional formatter 22 and, for certain complex text data, a conventional layout engine 24, and a conventional font 26. The conventional formatter 22, conventional layout engine 24, and font 26 might reside on a print server (not shown) or a desktop. The conventional formatter 22 formats a data stream to be printed. The data stream is encoded in Unicode. Consequently, the conventional formatter 22 uses the conventional layout engine 24 for Unicode complex text. The conventional layout engine 24 might be a Unicode layout engine such as the Uniscribe layout engine for WINDOWS. The conventional layout engine 24 can typically run on platforms such as Windows or UNIX. The font 26 may be an Open Type font that is used to render complex text.

[0007] The conventional layout engine 24 analyzes complex text data, such as Unicode complex text, and determines the appropriate glyph for a particular Unicode code word. The conventional layout engine 24 thus includes data related to languages and contexts. The conventional layout engine 24 utilizes this data to analyze complex text, determine contexts and thus determine the appropriate glyph. The conventional layout engine 24 thus also uses the font 26. For example, if the font 26 is an Open Type font, the conventional layout engine 24 would determine the appropriate glyph and, using the font 26, determine the appropriate glyph indices. Alternatively, the conventional layout engine 24 might determine a bit pattern for the glyph using the conventional rasterizer 28. This would occur when the printer 30 does not support the font 26. For example, the conventional layout engine 24 might use the font 26 to determine the appropriate glyph indices and, using the glyph indices, the appropriate glyph. The conventional rasterizer 28 might then output a bit pattern of the appropriate glyph.

[0008]FIG. 2 depicts a conventional method 50 for printing text encoded using Unicode and including Unicode complex text. The print data is obtained, for example from a client, via step 52. The conventional layout engine 24 in the computer system 20 is used to convert any Unicode complex text in the print stream into glyphs, via step 54. In order to perform step 54, the conventional layout engine 24 utilizes the font, described above. In converting the Unicode complex text into glyphs in step 54, the conventional layout engine 24 and conventional rasterizer 28 typically output the bit patterns of the glyphs.

[0009] The remaining portion of the Unicode text, which is not Unicode complex text, is rendered using one-to-one rendering, via step 56. The result of one-to-one rendering is bit patterns. In addition, in contrast to the Unicode complex text, one-to-one rendering might take place in the conventional printer 30 rather than in the conventional computer system 20. The conventional data stream, which includes bit patterns for Unicode complex text and Unicode code words for the remaining Unicode text, is passed to the conventional printer 30 for printing, via step 58. The conventional data stream also includes the locations of the glyphs. The conventional printer 30 then prints the data stream using the conventional rasterizer 34, via step 60. Step 60 might include performing one-to-one rendering for Unicode data that is not complex. Step 60 also includes placing the glyphs in the appropriate positions on the page.

[0010] Although the conventional system 10 and conventional method 50 function, one of ordinary skill in the art will readily recognize that there are drawbacks. The data for the Unicode complex text that is passed to the printer 30 is typically in the form of bit patterns. In any case, the code words for the Unicode complex text are not passed to the conventional printer 30. Once the bit patterns are generated, neither the computer system 20 nor the conventional printer 30 has any knowledge of the text represented by the data corresponding to the Unicode complex text. The data stream can no longer be processed for text operations, such as sorting, searching, indexing, merging or repurposing. In addition, bit patterns for a glyph are relatively large in comparison to the corresponding Unicode code words. Consequently, the transmission of data between the conventional computer system 20 and the conventional printer 30 may be inefficient and time consuming.

[0011] Accordingly, what is needed is an improved system and method for printing Unicode complex text data. The present invention addresses such a need.

SUMMARY OF THE INVENTION

[0012] The present invention provides a method and system for providing a printer for printing an encoded data stream. The data stream includes a section of complex text data. The code is preferably Unicode, and the complex text data is preferably Unicode complex text. The printer comprises a font, a text parser, a rasterizer, and a layout engine. The font includes a plurality of glyphs. The text parser is coupled with the font and parses the data stream to determine the section of complex text data in the data stream. The complex text data could already be identified by some mark generated by the formatter. The layout engine is coupled to the text parser and with the font. The layout engine receives the section of complex text data from the text parser and determines at least one of the plurality of glyphs corresponding to the section of complex text data.

[0013] According to the system and method disclosed herein, the present invention provides a printer capable of printing a data stream including complex text such as Unicode complex text. Thus, data transmission may be more efficient and the ability to perform additional text operations on the data stream being printed is preserved.

BRIEF DESCRIPTION OF THE DRAWINGS

[0014]FIG. 1 is a diagram of a conventional computer system that may be used in printing encoded data.

[0015]FIG. 2 is a flow chart depicting a conventional method for printing encoded data including complex text data.

[0016]FIG. 3 is a block diagram depicting one embodiment of a computer system using a printer in accordance with the present invention that prints complex text data represented using a code such as Unicode.

[0017]FIG. 4 is a block diagram depicting one embodiment of a printer in accordance with the present invention that prints complex text data represented using a code such as Unicode.

[0018]FIG. 5 is a high-level flow chart depicting one embodiment of a method in accordance with the present invention for printing data represented using a code.

DETAILED DESCRIPTION OF THE INVENTION

[0019] The present invention relates to an improvement in printers. The following description is presented to enable one of ordinary skill in the art to make and use the invention and is provided in the context of a patent application and its requirements. Various modifications to the preferred embodiment will be readily apparent to those skilled in the art and the generic principles herein may be applied to other embodiments. Thus, the present invention is not intended to be limited to the embodiment shown, but is to be accorded the widest scope consistent with the principles and features described herein.

[0020] The present invention provides a method and system for providing a printer for printing a data stream that includes a section of complex text data. The data stream is preferably Unicode data, and the complex text data is preferably Unicode complex text data. The printer comprises a font, a text parser, and a layout engine. The font includes a plurality of glyphs. The text parser is coupled with the font and parses the data stream to determine the section of complex text data in the data stream. The layout engine is coupled to the text parser and with the font. The layout engine receives the section of complex text data from the text parser and determines at least one of the plurality of glyphs corresponding to the section of complex text data.

[0021] The present invention will be described in terms of a particular printer having particular components. However, one of ordinary skill in the art will readily recognize that this method and system will operate effectively for other printers and other and/or additional components not inconsistent with the present invention. The present invention is also described in the context of a single section of complex text data in a data stream. However, one of ordinary skill in the art will readily recognize that the method and system operate effectively for multiple sections of complex text data in a data stream as well as multiple data streams. Finally, the present invention is described in terms of a preferred embodiment utilizing Unicode complex text. One of ordinary skill in the art will recognize, however, that the present invention can operate effectively for other encoding schemes and other types of data.

[0022] To more particularly illustrate the method and system in accordance with the present invention, refer now to FIG. 3, depicting one embodiment of a system 100 that uses a printer 110 in accordance with the present invention that prints complex text data represented using a code such as Unicode. The system 100 is described in the context of Unicode. However, one of ordinary skill in the art will readily recognize that the system 100 can be extended to other encoding schemes. The system 100 preferably includes a computer system 102. The computer system 102 preferably includes one or more clients 104 and a server 106. However, in an alternate embodiment, the computer system 102 could be a desktop. The system 100 includes a formatter 108. In one embodiment, the formatter 108 is essentially a conventional formatter that provides encoded data in a data stream to be printed. However, in another embodiment, the formatter 108 would mark sections of the print stream that include complex text data, such as Unicode complex text. In such an embodiment, the formatter 108 would preferably mark a section of complex text in a data stream provided from the computer system 102 to the printer 110.

[0023] The printer 110 is capable of receiving a data stream of encoded data which includes one or more sections of complex text. The printer 110 renders the data stream, including the section(s) of complex text within the data stream. Thus, data stream including Unicode complex text can be provided to the printer 110, then rendered. As a result, the Unicode code words are preserved even in the printer 110. Consequently, the text being printed can be searched, sorted or have other analogous operations performed before or after being sent to the printer 110. In addition, because the code words for characters are typically significantly smaller than bit patterns for glyphs, the transmission of the data stream to the printer 110 may be performed more efficiently.

[0024]FIG. 4 is a block diagram depicting one embodiment of a printer 110 in accordance with the present invention that prints complex text data represented using a code such as Unicode. The printer 110 is thus described in the context of Unicode and Unicode complex text. However, the printer 110 may operate effectively for other encoding schemes. The printer 110 receives the data stream from the computer system 102. The printer 110 includes a text parser 112, a layout engine 114, a font 116 and a rasterizer 118.

[0025] The text parser 112 receives the data stream provided to the printer 110. The text parser 112 parses the data stream to determine sections of complex text data, such as Unicode complex text, in the data stream. The data stream identifies the font to be used. In a preferred embodiment, the text parser 112 searches the data stream for Unicode code words within particular ranges. The ranges correspond to complex languages, such as Arabic or Thai, which are associated with Unicode complex text. In Unicode, code words for particular languages lie within a corresponding range. Consequently, searching for code words within ranges corresponding to the complex languages allows the text parser 112 to determine code words that correspond to Unicode complex text. Also in a preferred embodiment, the text parser 112 can thus determine the start and end of sections of complex text in the data stream. In an alternate embodiment, the text parser 112 locates the complex text based on marks made by the formatter 108. The text parser 112 also passes the corresponding complex text, as well as the appropriate locations, to the layout engine 114. The text parser 112, in combination with the font 116 and the rasterizer 118 performs one-to-one rendering on the remaining portion of the data stream not including complex text data. Preferably, the text parser 112 passes the remaining portion of the data stream not including complex text data to the rasterizer 118, which performs one-to-one rendering to convert the text data to glyphs. In addition, the positions of the glyphs in the page are also determined.

[0026] The layout engine 114, which is located in the printer 110, analyzes complex text data, such as Unicode complex text, from the text parser 112. The layout engine 114 is preferably substantially the same as the conventional layout engine. The layout engine 114 performs language dependent processing and determines the appropriate glyphs and glyph positions for the Unicode code words in the sections of complex text data from the text parser 112. Note that the glyphs could include null glyphs, which have no active elements in their bitmaps, such as a space. The layout engine 114 thus includes data related to languages and contexts. The layout engine 114 utilizes this data to analyze complex text, determine contexts, and direction and thus determines the appropriate glyphs, glyph positions and text direction. The layout engine 114 thus also uses the font 116. For example, the font 116 is preferably an Open Type font. The layout engine 114 would determine the appropriate glyphs and, using the font 116, determine the appropriate glyph indices. The layout engine 114 might then use the font 116, including passing the glyph indices to the font 116 or accessing the resources of the font 116. The layout engine 114 might pass the glyph indices and positions to the rasterizer 118. The rasterizer 118 then uses the glyph indices and the font 116 to retrieve the glyphs, and to rasterizer the glyphs into bit maps. The bit maps are then positioned using the information from the layout engine 114.

[0027] The font 116 is selected by the data stream. Thus, the font 116 is subject to change. In a preferred embodiment, the font 116 is an Open Type font. However, in an alternate embodiment, the font 116 might be another type of font. In a preferred embodiment, the font 116 includes an encoding table 120 and a glyph table 122. The encoding table 120 matches Unicode code words with corresponding glyph indices for the font being used. The glyph table 122 matches glyph indices with corresponding glyphs. To perform one-to-one rendering, the text parser 112 passes Unicode code words to the rasterizer 118, which uses the font 116 to map the code words first to glyph indices and then to glyphs. In other words, to print a portion of the data stream not including complex text, the rasterizer 118 uses the font 116 to convert Unicode code words to glyphs, preferably by one-to-one rendering that converts Unicode code words to glyph indices using the encoding table 120 and then converts the glyph indices to glyphs using the glyph table 122. To print sections of complex text in the data stream, the rasterizer 118 preferably receives glyph indices and positions from the layout engine 114. The font 116 converts the glyph indices to the appropriate glyphs using the glyph table 122. Thus, the text parser 112 in combination with the layout engine 114 and font 116 locates the complex text, utilizes the layout engine 114 to determine the appropriate glyphs, for example in the form of glyph indices, and uses the font 116 to obtain the actual glyphs.

[0028] The appropriate glyphs and their positions for the data stream are passed to the rasterizer 118. The rasterizer 118 places the glyphs for the data stream in the corresponding locations on the page. The data stream can then be printed, for example using a print device (not shown) and/or other components.

[0029] Thus, the printer 110 is capable of receiving a data stream of code and which includes one or more sections of complex text. The printer 110 renders the data stream, including the section(s) of complex text within the data stream. Thus, data stream including Unicode complex text can be provided to the printer 110, then rendered. As a result, the Unicode code words are preserved even in the printer 110. Consequently, the text being generated by the computer system can be searched, sorted or have other analogous operations performed before or after being sent to the printer 110. In addition, because the code words for characters are typically significantly smaller than bit patterns, the transmission of the data stream to the printer 110 may be performed more efficiently.

[0030]FIG. 5 is a high-level flow chart depicting one embodiment of a method 200 in accordance with the present invention for printing encoded text data. The method 200 is preferably implemented using the printer 110. Thus, the method 200 is described in the context of the system 100 and printer 110. The method 200 is also described in the context of Unicode, which is a preferred embodiment. However, the method 200 may operate effectively for other encoding schemes. The method 200 preferably commences after the printer 110 has begun receiving the data stream from the computer system 102. The data stream may include one or more sections of Unicode complex text. The data stream is parsed to identify sections of complex text data, such as Unicode complex text, via step 202. Step 202 is preferably performed using the text parser 112. Also in a preferred embodiment, step 202 is performed by searching the data stream for Unicode code words in particular ranges. Glyphs for the sections of complex text data that are identified in step 202 are determined using the layout engine 114, via step 204. Thus, step 204 includes processing which is language and font dependent in order to identify the appropriate glyphs for the Unicode complex text. In a preferred embodiment, step 204 includes outputting the appropriate glyph indices from the layout engine 114. The glyphs for remaining portions of the data stream, which do not include complex text, are determined preferably using one-to-one rendering, via step 206. Step 206 is preferably performed using the font 116. The glyphs determined in step 204 and 206 are placed in the appropriate positions on the paper, via step 208. In a preferred embodiment, step 208 is performed using the rasterizer 118.

[0031] Thus, the method 200 receives a data stream of code that includes one or more sections of complex text. The method 200 renders the data stream in the printer 110, including the section(s) of complex text within the data stream. Thus, data streams including Unicode complex text can be provided to the printer 110, then rendered. As a result, the Unicode code words are preserved even in the printer 110. Consequently, the text generated by the computer system 100 can be searched, sorted or have other analogous operations performed before or after being sent to the printer 110. In addition, because the code words for characters are typically significantly smaller than bit patterns, the transmission of the data stream to the printer 110 may be performed more efficiently.

[0032] A method and system has been disclosed for providing a printer capable of printing complex text data from a data stream of code. Software written according to the present invention is to be stored in some form of computer-readable medium, such as memory, CD-ROM or transmitted over a network, and executed by a processor. Consequently, a computer-readable medium is intended to include a computer readable signal which, for example, may be transmitted over a network. Although the present invention has been described in accordance with the embodiments shown, one of ordinary skill in the art will readily recognize that there could be variations to the embodiments and those variations would be within the spirit and scope of the present invention. Accordingly, many modifications may be made by one of ordinary skill in the art without departing from the spirit and scope of the appended claims. 

What is claimed is:
 1. A printer for printing an encoded data stream, the data stream capable of including a section of complex text data, the printer comprising: a text parser for parsing the encoded data stream to determine the section of complex text data in the encoded data stream; at least one font including a plurality of glyphs; and a layout engine coupled to the text parser and with the at least one font, the layout engine for receiving the section of complex text data from the text parser and for determining at least one of the plurality of glyphs corresponding to the section of complex text data.
 2. The printer of claim 1 further comprising: a rasterizer, coupled with the layout engine, the text parser and the at least one font, the rasterizer for positioning the at least one of the plurality of glyphs on at least one portion of a page corresponding to the section of complex text data.
 3. The printer of claim 1 wherein the at least one font includes an encoding table and a glyph table, the encoding table including a plurality of codes and a plurality of glyph indices corresponding to the plurality of codes, the glyph table including the plurality of glyphs corresponding to the plurality of glyph indices.
 4. The printer of claim 3 wherein the at least one glyph can include a null glyph.
 5. The printer of claim 3 wherein the layout engine determines the at least one glyph by determining at least one index of the plurality of glyph indices for the section of complex text data and at least one position for the at least one glyph.
 6. The printer of claim 3 wherein the text parser provides a remaining portion of the data stream not including the section of complex text data to the rasterizer to perform one-to-one rendering of a remaining portion of the data stream.
 7. The printer of claim 1 wherein the code is Unicode and wherein the section of complex text data includes Unicode complex text.
 8. The printer of claim 7 wherein the text parser determines the section of complex text data based upon at least one code word for the section of complex text data.
 9. The printer of claim 1 wherein the text parser determines the section of complex text data based upon at least one marker for the section of complex text data.
 10. A printer for printing an encoded data stream, the data stream capable of including a section of complex text data, the printer comprising: means for parsing data for determining the section of complex text data in the data stream; and at least one font including a plurality of glyphs, layout means, coupled to the parsing means and with the at least one font defining means, the layout means for receiving the section of complex text data from the text parser and for determining at least one of the plurality of glyphs corresponding to the section of complex text data.
 11. A method for printing an encoded data stream, the data stream capable of including a section of complex text data, the method comprising the steps of: (a) parsing the data stream in a printer to determine the section of complex text data in the data stream; and (b) utilizing a layout engine to receive the section of complex text data from the text parser and to determine at least one of the plurality of glyphs corresponding to the section of complex text data.
 12. The method of claim 11 further comprising the step of: (c) positioning the at least one of the plurality of glyphs on at least one portion of a page corresponding to the section of complex text data.
 13. The method of claim 11 further comprising the step of: (c) utilizing an encoding table including a plurality of codes and a plurality of glyph indices corresponding to the plurality of codes, the glyph table including the plurality of glyphs corresponding to the plurality of glyph indices.
 14. The method of claim 13 wherein the layout engine determines the at least one glyph by determining at least one index of the plurality of glyph indices for the section of complex text data and at least one position for the at least one glyph.
 15. The method of claim 13 further comprising the step of: (d) utilizing a rasterizer to perform one-to-one rendering of a remaining portion of the encoded data stream not including the section of complex text data.
 16. The method of claim 11 wherein the code is Unicode and wherein the section of complex text data includes Unicode complex text.
 17. The method of claim 16 wherein the data parsing step (a) further includes the step of: (a1) determining the section of complex text data based upon at least one code word for the section of complex text data.
 18. The method of claim 11 wherein the data parsing step (a) further includes the step of: (a1) determining the section of complex text data based upon at least one marker for the section of complex text data. 